home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
The CICA Windows Explosion!
/
The CICA Windows Explosion! - Disc 2.iso
/
demo
/
cfxwdemo.zip
/
INSTSES.MST
< prev
next >
Wrap
Text File
|
1995-06-21
|
9KB
|
332 lines
''**************************************************************************
''* ColorLink for Windows Setup Script "install.mst"
''**************************************************************************
'$DEFINE DEBUG ''Define for script development/debugging
'$INCLUDE 'setupapi.inc'
'$INCLUDE 'msdetect.inc'
''Dialog ID's
CONST WELCOME = 100
CONST WELCOME_RECV = 101
CONST WELCOME_RECV1 = 102
CONST WELCOME_DEMO = 103
CONST ASKQUIT = 200
CONST DESTPATH = 300
CONST EXITFAILURE = 400
CONST EXITQUIT = 600
CONST EXITSUCCESS = 700
CONST OPTIONS = 800
CONST CHECK = 2500
CONST APPHELP = 900
CONST BADPATH = 6400
CONST CDGETNAMEORG =7500
CONST NOTESCSI =8000
''Bitmap ID
CONST LOGO = 1
GLOBAL DEST$ ''Default destination directory.
GLOBAL OPTCUR$ ''Option selection from option dialog.
DECLARE SUB Install
DECLARE FUNCTION MakePath (szDir$, szFile$) AS STRING
''Customized Functions
CONST SW_MAXIMIZED=3
DECLARE FUNCTION ShowFrame LIB "mscuistf.dll" (Hwnd%, Show%) AS INTEGER
DECLARE FUNCTION SaveCustomerInfo LIB "mscuistf.dll" (Profile$, S1$, S2$, S3$) AS INTEGER
DECLARE FUNCTION GetWinSysDir LIB "mscuistf.dll" (SYSDIR$) AS INTEGER
INIT:
PRODCAT$ = "Demo"
CUIDLL$ = "mscuistf.dll" ''Custom user interface dll
HELPPROC$ = "FHelpDlgProc" ''Help dialog procedure
S0$ = "" ''product Type
S1$ = "" ''Customer Name
S2$ = "" ''Customer organization
S3$ = "" ''Serial number
SetSymbolValue "ProdType",S0$
SetSymbolValue "NameOut",S1$
SetSymbolValue "OrgOut",S2$
SetSymbolValue "SerialOut",S3$
SetBitmap CUIDLL$, LOGO
SetTitle "Install ColorLink for Windows"
szInf$ = GetSymbolValue("STF_SRCINFPATH")
IF szInf$ = "" THEN
szInf$ = GetSymbolValue("STF_CWDDIR") + "SETUP.INF"
END IF
ReadInfFile szInf$
OPTCUR$ = "1"
DEST$ = "C:\CLDEMO"
'$IFDEF DEBUG
i% = SetSizeCheckMode(scmOnIgnore) '' could use scmOff; def = scmOnFatal
WinDrive$ = MID$(GetWindowsDir, 1, 1)
IF IsDriveValid(WinDrive$) = 0 THEN
i% = DoMsgBox("Windows drive ('"+WinDrive$+"') is not a valid drive.", "DEBUG", MB_TASKMODAL+MB_ICONHAND+MB_OK)
GOTO QUIT
END IF
'$ENDIF ''DEBUG
WELCOME:
SetSymbolValue "HelpOn","WELCOME"
IF PRODCAT$ = "Universal" THEN
sz$ = UIStartDlg(CUIDLL$, WELCOME, "FInfoDlgProc", APPHELP, HELPPROC$)
ELSEIF PRODCAT$ = "Demo" THEN
sz$ = UIStartDlg(CUIDLL$, WELCOME_DEMO, "FInfoDlgProc", APPHELP, HELPPROC$)
ELSE
sz$ = UIStartDlg(CUIDLL$, WELCOME_RECV, "FInfoDlgProc", APPHELP, HELPPROC$)
ENDIF
IF sz$ = "CONTINUE" THEN
UIPop 1
x%=ShowFrame(HwndFrame(),SW_MAXIMIZED)
ELSE
GOSUB ASKQUIT
GOTO WELCOME
END IF
SIGNUP:
IF PRODCAT$ = "Universal" THEN
sz$ = UIStartDlg(CUIDLL$, CDGETNAMEORG, "FNameOrgDlgProc", 0, "")
S1$ = GetSymbolValue("NameOut")
S2$ = GetSymbolValue("OrgOut")
S3$ = GetSymbolValue("SerialOut")
IF sz$ = "CONTINUE" THEN
UIPop 1
ELSEIF sz$ = "REACTIVATE" THEN
GOTO SIGNUP
ELSEIF sz$ = "BACK" THEN
UIPop 1
GOTO WELCOME
ELSEIF sz$ = "EXIT" THEN
GOSUB ASKQUIT
GOTO SIGNUP
END IF
END IF
OPTION:
SetSymbolValue "HelpOn","OPTION"
CHECKIN$ = "CheckItemsIn"
nList% = GetListLength(CHECKIN$)
IF nList% = 0 THEN
AddListItem CHECKIN$,"ON"
AddListItem CHECKIN$,"OFF"
ENDIF
GOTO GETPATH
OPTL1:
sz$ = UIStartDlg(CUIDLL$, CHECK, "FCheckDlgProc", APPHELP, HELPPROC$)
nList% = GetListLength("CheckItemsOut")
FOR i% =1 TO nList% STEP 1
szOption$ = GetListItem("CheckItemsOut", i%)
ReplaceListItem CHECKIN$, i%, szOption$
NEXT
IF sz$ = "CONTINUE" THEN
UIPop(1)
ELSEIF sz$ = "REACTIVATE" THEN
GOTO OPTL1
ELSEIF sz$ = "BACK" THEN
UIPop 1
GOTO SIGNUP
ELSE
GOSUB ASKQUIT
GOTO OPTION
END IF
GETPATH:
SetSymbolValue "HelpOn","GETPATH"
SetSymbolValue "EditTextIn", DEST$
SetSymbolValue "EditFocus", "END"
GETPATHL1:
sz$ = UIStartDlg(CUIDLL$, DESTPATH, "FEditDlgProc", APPHELP, HELPPROC$)
DEST$ = GetSymbolValue("EditTextOut")
IF sz$ = "CONTINUE" THEN
IF IsDirWritable(DEST$) = 0 THEN
GOSUB BADPATH
GOTO GETPATHL1
END IF
UIPop 1
ELSEIF sz$ = "REACTIVATE" THEN
GOTO GETPATHL1
ELSEIF sz$ = "BACK" THEN
UIPop 1
IF PRODCAT$ = "Universal" THEN
GOTO SIGNUP
ELSE
GOTO WELCOME
ENDIF
ELSE
GOSUB ASKQUIT
GOTO GETPATH
END IF
DOINSTALL:
Install
''Save customer information
IF PRODCAT$ = "Demo" THEN
x%=FCreateIniKeyValue("WIN.INI", "CLFWS", "EXEC", "rBQY", cmoNone)
ELSE
x%=SaveCustomerInfo("COLORLNK.INI", S1$, S2$, S3$) ''under Windows directory
ENDIF
QUIT:
''ON ERROR GOTO ERRQUIT
IF ERR = 0 THEN
dlg% = EXITSUCCESS
ELSEIF ERR = STFQUIT THEN
dlg% = EXITQUIT
ELSE
dlg% = EXITFAILURE
END IF
QUITL1:
sz$ = UIStartDlg(CUIDLL$, dlg%, "FInfo0DlgProc", 0, "")
IF sz$ = "REACTIVATE" THEN
GOTO QUITL1
END IF
UIPop 1
IF dlg% = EXITSUCCESS THEN
GOTO ENDINSTALL
ELSE
GOTO ENDINSTALL
ENDIF
NOTESCSI:
sz$ = UIStartDlg(CUIDLL$, NOTESCSI, "FInfo0DlgProc", 0, "")
IF sz$ = "REACTIVATE" THEN
GOTO NOTESCSI
END IF
UIPop 1
ENDINSTALL:
END
''End of program
ERRQUIT:
''i% = DoMsgBox("Setup sources were corrupted, call 555-1212!", "Setup Message", MB_OK+MB_TASKMODAL+MB_ICONHAND)
END
BADPATH:
sz$ = UIStartDlg(CUIDLL$, BADPATH, "FInfo0DlgProc", 0, "")
IF sz$ = "REACTIVATE" THEN
GOTO BADPATH
END IF
UIPop 1
RETURN
ASKQUIT:
sz$ = UIStartDlg(CUIDLL$, ASKQUIT, "FQuitDlgProc", 0, "")
IF sz$ = "EXIT" THEN
UIPopAll
ERROR STFQUIT
ELSEIF sz$ = "REACTIVATE" THEN
GOTO ASKQUIT
ELSE
UIPop 1
END IF
RETURN
'**
'** Purpose:
'** Builds the copy list and performs all installation operations.
'** Arguments:
'** none.
'** Returns:
'** none.
'*************************************************************************
SUB Install STATIC
CreateDir DEST$, cmoNone
''OpenLogFile MakePath(DEST$, "LOGFILE.OUT"), 0
''WriteToLogFile ""
''WriteToLogFile " User chose as destination directory: '" + DEST$ + "'"
''WriteToLogFile " User chose option: '" + OPTCUR$ + "'"
''WriteToLogFile ""
''WriteToLogFile "May have had to create the directory: " + DEST$
''WriteToLogFile ""
''AddSectionFilesToCopyList "Files", SrcDir$, DEST$
''AddSectionKeyFileToCopyList "Options", OPTCUR$, SrcDir$, DEST$
''get ColorLink option
SrcDir$ = GetSymbolValue("STF_SRCDIR")
CHECKIN$ = "CheckItemsIn"
OPSTR1$ = GetListItem(CHECKIN$, 1)
IF OPSTR1$ = "ON" THEN
AddSectionFilesToCopyList "Files", SrcDir$, DEST$
ENDIF
''get SCSI option
OPSTR2$ = GetListItem (CHECKIN$, 2)
IF OPSTR2$ = "ON" THEN
''AddSectionFilesToCopyList "SCSI", SrcDir$, DEST$
''Get Windows system directoy
SYSDIR$ = STRING$(255, 0)
x%=GetWinSysDir(SYSDIR$)
AddSectionFilesToCopyList "SCSI", SrcDir$, SYSDIR$
ENDIF
CopyFilesInCopyList
''GOSUB SIGNUP
''ini$ = MakePath(DEST$, "DEMO.INI")
''CreateIniKeyValue "WIN.INI", "MSSetup Sample 1", "Option", OPTCUR$, cmoNone
''CreateIniKeyValue ini$, "Section 1", "Key 1", "Value 1" , cmoNone
''CreateIniKeyValue ini$, "Section 2", "Key 2", "Value 2" , cmoNone
''CreateIniKeyValue ini$, "Section 3", "Key 3", "Value 3" , cmoNone
IF OPSTR1$="ON" THEN
CreateProgmanGroup "Laser Today", "", cmoNone
ShowProgmanGroup "Laser Today", 1, cmoNone
CreateProgmanItem "Laser Today", "Read Me", "write.exe "+MakePath(DEST$,"readme.wri"), "", cmoOverwrite
CreateProgmanItem "Laser Today", "ColorLink Demo.", MakePath(DEST$,"colorlnk.exe"), "", cmoOverwrite
ENDIF
''AddDos5Help "YOURAPP", "A brief help text for your Windows application."+chr$(10)+"It can be continued on another line with chr$(10).", cmoNone
''CloseLogFile
END SUB
'**
'** Purpose:
'** Appends a file name to the end of a directory path,
'** inserting a backslash character as needed.
'** Arguments:
'** szDir$ - full directory path (with optional ending "\")
'** szFile$ - filename to append to directory
'** Returns:
'** Resulting fully qualified path name.
'*************************************************************************
FUNCTION MakePath (szDir$, szFile$) STATIC AS STRING
IF szDir$ = "" THEN
MakePath = szFile$
ELSEIF szFile$ = "" THEN
MakePath = szDir$
ELSEIF MID$(szDir$, LEN(szDir$), 1) = "\" THEN
MakePath = szDir$ + szFile$
ELSE
MakePath = szDir$ + "\" + szFile$
END IF
END FUNCTION